#include <bits/stdc++.h>
using namespace std;
#define int long long
//#define endl '\n'
int n;
pair<int,char> getlevel(int u){
int lvl = 1;
int v = n/2;
char last;
while(v != u){
if (v > u) v -= n/(1ll<<(++lvl)), last = 'L';
else v += n/(1ll<<(++lvl)), last = 'R';
}
return {lvl,last};
}
signed main() {
cin.tie(NULL); cout.tie(NULL); ios::sync_with_stdio(0);
int q;cin>>n>>q;
++n;
int mx = log2(n);
while(q--){
int u;cin>>u;
string s;cin>>s;
auto [lvl,pos] = getlevel(u);
for(auto &x:s){
if (x == 'U'){
if (lvl > 1)
u += (n/(1ll<<(lvl))) * (pos == 'L' ? 1 : -1);
}
if (x == 'L'){
if (lvl < mx)
u -= (n/(1ll<<(lvl+1)));
}
if (x == 'R'){
if (lvl < mx)
u += (n/(1ll<<(lvl+1)));
}
lvl = getlevel(u).first;
pos = getlevel(u).second;
}
cout<<u<<endl;
}
return 0;
}
733. Flood Fill | 206. Reverse Linked List |
83. Remove Duplicates from Sorted List | 116. Populating Next Right Pointers in Each Node |
145. Binary Tree Postorder Traversal | 94. Binary Tree Inorder Traversal |
101. Symmetric Tree | 77. Combinations |
46. Permutations | 226. Invert Binary Tree |
112. Path Sum | 1556A - A Variety of Operations |
136. Single Number | 169. Majority Element |
119. Pascal's Triangle II | 409. Longest Palindrome |
1574A - Regular Bracket Sequences | 1574B - Combinatorics Homework |
1567A - Domino Disaster | 1593A - Elections |
1607A - Linear Keyboard | EQUALCOIN Equal Coins |
XOREQN Xor Equation | MAKEPAL Weird Palindrome Making |
HILLSEQ Hill Sequence | MAXBRIDGE Maximise the bridges |
WLDRPL Wildcard Replacement | 1221. Split a String in Balanced Strings |
1002. Find Common Characters | 1602A - Two Subsequences |